.pattern-wrapper {
  z-index: 99;
  position: absolute;
  left: 10px;
  top: 10px;
  width: 60px;
  display: flex;
  flex-direction: column;
  align-items: center;
  background: rgba(255, 255, 255, .8);
  box-shadow: 0 1px 4px rgba(0, 0, 0, .3);
  padding: 10px 0;
  font-size: 12px;
  color: #676768;
  user-select: none;

  .name {
    text-align: center;
  }

  .pattern-item {
    width: 36px;
    height: 36px;
    margin: 0 auto;
    cursor: pointer;
    background-position: center;
    background-repeat: no-repeat;

    &.selection {
      background-image: url();
    }

    &.start {
      background-image: url();
    }

    &.end {
      background-image: url();
    }

    &.user {
      background-image: url();
    }

    &.condition {
      background-image: url();
    }
  }
}
